Merge pull request #8892 from iNavFlight/MrD_Show-loiter-instead-of-poshold-in-OSD...
[inav.git] / docs / INAV PID Controller.md
blob7bf5945e48f918929500a19018289b723059212e
1 # INAV PID Controller
3 What you have to know about INAV PID/PIFF/PIDCD controllers:
5 1. INAV PID uses floating-point math
6 1. Rate/Angular Velocity controllers work in dps [degrees per second]
7 1. P, I, D and Multirotor CD gains are scaled like Betafligfht equivalents, but actual mechanics are different, and PID response might be different
8 1. Depending on platform type, different controllers are used
9     1. Fixed-wing uses **PIFF**:
10         1. Error is computed with a formula `const float rateError = pidState->rateTarget - pidState->gyroRate;`
11         1. P-term with a formula `rateError * pidState->kP`
12         1. Simple I-term without Iterm Relax. I-term limit based on stick position is used instead. I-term is no allowed to grow if stick (roll/pitch/yaw) is deflected above threshold defined in `fw_iterm_limit_stick_position`. `pidState->errorGyroIf += rateError * pidState->kI * dT;`
13         1. No D-term
14         1. FF-term (Feed Forward) is computed from the controller input with a formula `pidState->rateTarget * pidState->kFF`. Bear in mind, this is not a **FeedForward** from Betaflight!
15     1. Multirotor uses **PIDCD**:
16         1.  Error is computed with a formula `const float rateError = pidState->rateTarget - pidState->gyroRate;`
17         1. P-term with a formula `rateError * pidState->kP`
18         1. I-term
19             1. Iterm Relax is used to dynamically attenuate I-term during fast stick movements
20             1. I-term formula `pidState->errorGyroIf += (itermErrorRate * pidState->kI * antiWindupScaler * dT) + ((newOutputLimited - newOutput) * pidState->kT * antiWindupScaler * dT);`
21             1. I-term can be limited when motor output is saturated
22         1. D-term is computed only from gyro measurement
23         1. There are 2 LPF filters on D-term 
24         1. D-term can by boosted during fast maneuvers using D-Boost. D-Boost is an equivalent of Betaflight D_min
25         1. **Control Derivative**, CD, or CD-term is a derivative computed from the setpoint that helps to boost PIDCD controller during fast stick movements. `newCDTerm = rateTargetDeltaFiltered * (pidState->kCD / dT);` It is an equivalent of Betaflight Feed Forward